<template>
  <div class="todo-header">
    <input type="text" placeholder="请输入你的任务名称，按回车键确认" v-model="title" @keyup.enter ="add"/>
  </div>
</template>

<script>
/* 通过命令 npm i nanoid 安装nanoid库，调用之后会给我们一个唯一的字符串 */
import {nanoid} from 'nanoid'
export default {
  name: "MyHeader",
  data(){
    return{
      title:'',
    }
  },
  methods:{
    add(){
      /* 校验数据 判断如果为空，则不添加 */
      if(!this.title.trim()) return alert('输入不能为空')
      /* 将用户的输入包装成一个todo对象 */
      /*  console.log(e.target.value) */
      const todoObj = {id:nanoid(),title:this.title,done:false}
      /* console.log(todoObj) */
      /* 通知App组件去添加一个todo对象 */
      this.$emit('addTodo',todoObj)
      /*  操作了dom元素 */
        /* e.target.value = ''  */

      /* 清空输入 */
      this.title = ''
    }
  }
}
</script>

<style scoped>
  /*header*/
  .todo-header input {
    width: 560px;
    height: 28px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 4px 7px;
  }

  .todo-header input:focus {
    outline: none;
    border-color: rgba(82, 168, 236, 0.8);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(82, 168, 236, 0.6);
  }
</style>